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prinV server apparatus, information processing 
apparatus, print job reservation management method, 
reservation job generation method and memory medium 

5 background of the invention 
Field of the Invention 

The present invention relates to a server 
apparatus and a client apparatus for managing print 
data and print job information outputted from plural 
10 clients connected to a network to a network printer 
connected to such network, a print job management 
system therefor , a method therefor and a memory medium 
therefor. 

Related Background Art 

15 in the conventional environment utilizing the 

network printer, it has not been popular to directly 
transmit the print data from the plural clients on the 
network to the network printer. This is because, if 
the network printer receives plural print data from the 

20 plural client apparatus, there increases the load in 
sequence control and reception process, leading to an 
increase in the cost of the network printer in order to 
respond to such load. 

For this reason, there is often set a print server 

25 on the network, utilizing the operating system thereof. 
In such print job reservation system utilizing such 
print server, the printing operation is executed by 



-transferring the print data from a client to the print 
server, reserving such print data in a specified area 
of the print server, at the same time managing, by the 
print server, the order of printing in the network 
5 printer designated as the output destination of the 

print data, and reading and transmitting the reserved 
print data to the network printer when the order of 
printing is reached. 

In such case, the print server has to accept, for 

10 the network printer under the management thereof, the 
print data from plural clients on the network, so that 
the load of the print server inevitably increase with 
the increase in the number of the clients or the 
network printers. Therefore, in case the reservation 

15 medium (for example hard disk) for the print data in 
the print server becomes unavailable because of an 
error such as a deficiency in the memory capacity, it 
becomes impossible not only the reservation of the 
print data accepted from the client apparatus but also 

20 the transmission of the print data to the network 
printer. For this reason there has recently been 
conceived a system in which the print server only 
accepts print requests for the print jobs while the 
actual print data are retained by the clients, and the 

25 client apparatus directly transmits the print data to 
the network printer after a transmission permit is 
received from the print server. 



In order to resolve the drawback that the printing 
process cannot be executed by the trouble in the print 
server, the Japanese Patent Application Laid-Open No. 
10-240469 proposes a network print system and an 
5 information processing apparatus. In this system, 

however, since the print data retained in the client 
are deleted at the completion of the printing 
operation, it is not possible to reserve the print 
data, after normally completed printed process, in the 

10 server computer. 

Therefore, there can be conceived a print job 
reservation management system provided with a server 
computer including print end notifying means for 
judging the available writing capacity of a memory 

15 medium of the server computer (assumed as a hard disk 
of the computer for the purpose of simplicity but 
composable by a detachable medium such as a 
mangetooptical disk) and notifying a client computer of 
print end only in case the data reservation is possible 

20 but maintaining an unreservable print job in a waiting 
state for reservation, a client computer including 
reserved job transmission means which does not delete 
the print data at the reception of information for 
print end from the server computer but transmits the 

25 print data and the print job information collectively 

as a reservation job to the server computer and deletes 
the reservation job at the completion of transmission, 
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and reservation job management means for reserving the 
reservation job transmitted from the client computer in 
a designated directory, deleting periodically the 
reservation job after expiration of a designated 
5 reservation period, and notifying the print end 
notifying means of an increase in the available 
reservation capacity thereby enabling notification, for 
the reservation job that cannot be reserved on the 
server computer, of print end in asynchronous manner. 

10 In such system, a print job for which the print 

end is informed is retained in the designated directory 
of the server computer for the designated period, while 
a print job that cannot be reserved on the server 
computer is reserved in the reservation waiting state 

15 on the client computer requesting the printing 

operation. However, the job in the reservation waiting 
state is reserved in the designated directory of the 
server computer as the print end is informed in 
asynchronous manner as soon as the reservation capacity 

20 on the server computer becomes available. As a result, 
there can be prevented a situation where the print end 
job cannot be reserved on the server computer because 
of the deficiency in the reservation capacity thereof. 
Also in case of reprinting a reservation job 

25 reserved in the server computer, if the RAW data alone 
including the device information are reserved, the 
reprinting cannot be executed in another printer but is 



limited to a printer of the identical specification. 
Therefore, there can be conceived a print job 
reservation management system capable of reserving the 
RAW data and the EMF data collectively in a reservation 
5 job file thereby enabling reprinting of the reservation 
job according to the printer of destination. In 
addition, there has been a limitation that the 
reprinting can only be made on the same printer if the 
print data reserved in the reservation job file are RAW 
10 data. 

SUMMARY OF THE INVENTION 

The first object of the present invention is to 

judge the size of the print job data and the available 
15 capacity of the reservation directory on the server 

computer and to inform print end only in case the 

reservation is possible. 

The second object of the present invention is to 

transmit print data and print job information 
20 collectively as a reservation job to the server 

computer in response to the information of print end 

therefrom, and to delete the reservation job at the 

completion of the transmission. 

The third object of the present invention is to 
25 receive the reservation job transmitted from a client 

computer, to reserve the reservation job in a 

separately designated directory of the server computer, 
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and "to periodically delete the reservation job of which 
separately designated reservation period expires . 

The fourth object of the present invention is to 
store the RAW data and the EMF data simultaneously in 
5 the reservation job file, thereby enabling reprinting 
with limitation of the destination. 

The fifth object of the present invention is to 
select an arbitrary reservation job file reserved in 
the server computer, thereby enabling printing of the 
10 ordinary application level by directly transmitting the 
print data to a spooler or generating the print data by 
a printer driver through GDI, according to the print 
data (RAW or EMF) transmitted from the server. 

The sixth object of the present invention is to 
15 re-reserve the RAW data, generated at the re-printing, 
as a new reservation job file. 

Other features and advantages of the present 
invention will be apparent from the following 
description taken in conjunction with the accompanying 
20 drawings, in which like reference characters designate 
the same or similar parts throughout the figures 
thereof. 

BRIEF DESCRIPTION OF THE DRAWINGS 
25 Fig. 1 is a view showing the configuration of a 

network system in which the print job reservation 
management system of the present invention is applied; 



Fig. 2 is a block diagram showing the schematic 
configuration of a client computer in Fig. 1; 

Fig. 3 is a memory map of a program developed in a 
RAM shown n Fig. 2 from a FD shown in Fig. 4; 
5 Fig. 4 is a memory map representing data inside 

the FD shown in Fig. 2; 

Fig. 5 is a view showing the relationship between 
the client computer shown in Fig. 1 and the FD shown in 
Fig. 2; 

10 Fig. 6 is a view showing the configuration of 

software modules of a client computer and a server in 
an embodiment of the present invention; 

Fig. 7 is a view showing the configuration of a 
registry of a client; 
15 Fig. 8 is a view showing the configuration of a 

registry of a server; 

Fig. 9 is a view showing the configuration of a 

list; 

Fig. 10 is a view showing an example of the print 
20 setting image displayed on a display device of the 
client apparatus shown in Fig. 1; 

Fig. 11 is a flow chart showing the process flow 
of a print end notification unit of the present 
invention; 

25 Fig. 12 is a flow chart showing the process flow 

of a reservation job transmission unit of the present 
invention; 



Fig. 13 is a flow chart showing the process flow 
of a reservation job management unit of the present 
invention; 

Fig- 14 is a view showing a re-print GUI of the 
5 present invention; 

Fig. 15 is a flow chart showing the flowing of the 
re-print GUI of the present invention; 

Fig. 16 is a flow chart showing the flow of a re- 
print process of the reservation job transmission unit 
10 of the present invention; 

Fig. 17 is a flow chart showing the flow of a 
print data extraction process in the reservation job 
management unit of the present invention; and 

Fig. 18 is a view showing the memory map of a 
15 memory medium storing data processing programs readable 
by the server apparatus or the client apparatus of the 
present invention. 

DESCRIPTION OF THE PREFERRED EMBODIMENTS 
20 Fig. 1 is a block diagram showing the 

configuration of a printing system in which the print 
control apparatus of the present invention is 
applicable, particularly corresponding to a system for 
reservation management of the print jobs. In this 
25 embodiment, it is assumed that there are connected n 
client computers. 

Referring to Fig. 1, client computers 102, 103, 



104 are connected by network cables to a network 106, 
also capable of executing various programs such as 
application programs and are provided with a printer 
driver for preparing print data. 
5 A server 101 is connected by a network cable to 

the network 106. The server 101 of the present 
embodiment is provided with a function of storing print 
job information from the client computers 102, 103, 104 
as a summary file. 

10 A network printer 105, being connected to the 

network 106 through a network interface, prints the 
print data transmitted from the client computer. A 
network 106 is connected to the client computers, 
server and network printer. 

15 Fig. 2 is a block diagram showing the schematic 

configuration of the client computer 102 shown in Fig. 
1. The client computer 102, 103 have a same 
configuration . 

Referring to Fig. 2, a CPU 200 executes 

20 application programs, a printer driver program, an 
operating system ( OS ) , a print j ob reservation 
management program etc. stored in a hard disk (HD) 205, 
and temporarily stores information, files etc. 
necessary for the execution of programs in a RAM 202. 

25 A ROM 201 stores programs such as a basic 1/0 program, 
and various data such as font data and template data to 
be used for text processing. A RAM 202 serves as a 
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main memory and a work area of the CPU 200. 

A floppy disk ( FD ) drive 203 allows to load a 
program etc. stored in a floppy disk 204 into the 
present computer system. A FD 204 stores a print job 
5 reservation management program and related data, to be 
explained in the present embodiment, and Fig. 4 stores 
the configuration of the stored content. 

Referring to Fig. 4, there are shown a data 
content 400 of the FD 204, volume information 401 

10 indicating the information of the data, directory 

information 402, a print job reservation management 
program 403 to be explained in the present embodiment, 
and related data 404 therefor. The print job 
reservation management program 403 is reduced to 

15 program codes according to flow charts of the network 
printer control sequence shown in Figs. 15 to 20. 

An HD 205 stores application programs, a printer 
driver program, an OS, a print job reservation 
management program, related programs etc. A keyboard 

20 206 is used by the user for entering device control 
commands into the client computer. A display 207 
displays the command entered from the keyboard 206 and 
the status of the printer. A system bus 208 executes 
the data flow in the client computer. 

25 Fig. 3 is a memory map in a state where the 

network printer control program is loaded in the RAM 
202 and is rendered executable. In the present 



embodiment, there will be explained an example in which 
the print job reservation management program and 
related data are directly loaded from the FD 204 into 
the RAM 202 and executed therein, but they may also be 
5 loaded from the HD 205 to the RAM 202. Also the medium 
storing the print job reservation management program 
may be a CD-ROM or an IC card memory instead of FD. It 
is also possible to store the print job reservation 
management program in the ROM 201 as a part of the 
10 memory map and to execute such program directly by the 
CPU 200. 

A basic I/O program area 301 stores a program 
having an IPL (initial program loading) function 
causing the OS to be read from the HD 205 into the RAM 

15 202 and to be activated when the power supply of the 

present control apparatus is turned on. In areas 302, 
303, 304 there are respectively developed an OS, a 
print job reservation management program, and related 
data. An area 305 serves as a work area for executing 

20 the network printer control program by the CPU 200 . 

Fig. 6 is a view showing the configuration of 
software modules or a print system in which the client 
computer and the server embodying the present invention 
are applicable. These modules can be supplied, for 

25 example, from the FD. In Fig. 6, there are shown a 

software module configuration 501 of a client computer, 
a software module configuration 502 of a server, and a 
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network printer 503 . 

An application module 504 is used for preparing 
print data to be reserved by the print job reservation 
management system of the present invention. The 
5 application 504 prepares text data and outputs such 

data, in case of printing, as drawing data (GDI) to a 
GDI (graphic device interface) 508 constituting the 
drawing means of OSS. A printer driver 505 is 
incorporated and functions in the Windows OS ( trade 

10 name) of Microsoft Corp., U.S. 

There are also shown a printer spooler 506 in the 
Windows, a network printer control monitor 507, a print 
reservation job transmitting module 509 for 
transmitting reservation job data 510, prepared 

15 collectively from print data (FLAW and EMF in the 

present invention as will be explained later) and print 
job information, to the server, and a registry 511 to 
be registered in the Windows system and provided with a 
directory for retaining the name of a server of 

20 destination of transmission or the reservation job 
data. 

In case of printing with the application 504, the 
text data are outputted as a GDI function, constituting 
drawing data, to the GDI 508, which converts such GDI 
25 function into drawing commands executable by the driver 
and called a DDI (device driver interface) function. 
The printer driver 505, receiving the DDI function, 
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converts it into a printer language (page description 
language) interpretable by the network printer 503 for 
executing the printing. In the Windows OS, there can 
be executed spooling by a file of a device- independent 
5 intermediate data format called EMF (enhanced meta 
file). The EMF data reserve the drawing content in 
binary format, based on the GDI function issued by the 
application. Upon completion of spooling, the drawing 
content temporarily stored in an EMF spooler, 

10 represented by the EMF data, is outputted as the GDI 
function to the GDI 508. Also the print data in the 
format of a page description language, generated by the 
printer driver 505, are called RAW data. 

A reservation job management module 512 featuring 

15 the present invention serves to receive the reservation 
job data transmitted from the print reservation job 
transmitter 509 of the client computer by RPC (remote 
procedure call) or to transmit the designated print 
data. 

20 A server registry 513 registered in the Windows 

system controls the function of the print reservation 
job manager 512 according to set information such as 
the destination or period of reservation of the 
reservation job file. 

25 An end-of -print notice processor 514 receives an 

end-of -print event for the print data, transmitted from 
the monitor 507 of the client 102, from the network 
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printer 503, and, after judging whether the reservation 
is possible, sends an end-of-print notice to the print 
reservation job transmitter 509 by RPC. 

There are also shown a file 515 storing the 
5 reservation job, a job list 516, a reservation job list 
517, a list structure member 518 to be used as a 
reservation waiting job list, and a re-print GUI (re- 
print GUI providing module) 519 for providing a user 
interface for re-printing an arbitrary reservation job 

10 from the client. These modules constitute the print 
job reservation management system of the present 
invention, and are supplied from a memory medium which 
is the FD 204 in the present embodiment. 

Fig. 7 shows the data structure of the registry 

15 511 of the client 102 shown in Fig. 6, and shows a case 
where the registry is constituted by a server function 
information, a server name, a server IP address etc. 

Fig. 8 shows the data structure of the registry 
511 of the server 101 shown in Fig. 6, and shows a case 

20 where the registry is constituted by a log reservation 
destination, an error information, a log reservation 
period etc. 

Fig. 9 shows the data structure of the list 
structure of the server 101 shown in Fig. 6, and shows 
25 a case where it is constituted by an index, a job ID, a 
reservation job file name, a reservation job size, a 
log reservation period, a user name, a document name, a 
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printer name, a driver name, a next list address etc. 

In the following there will be explained a print 
job reservation management process in case the printing 
is executed in the network printer 105 from the client 
5 computer 102 in the above-described print system. 

In the present embodiment, explanation will be 
made on the print system based on an imaginary printer 
server system. The imaginary printer server system of 
the configuration shown in Fig. 6 executes the process 

10 in the following manner. When the printing is started 
from the application 504 on the client PC 501 (102), 
the present print control program accesses the EMF data 
which spool the drawing content issued from the 
application 504 and generates a copy in the reservation 

15 job data 510. Also the RAW data, which are a printer 
control language generated by the printer driver 505 
based on the print command from the GDI 508, are 
reserved also as print data in correlation, by an 
identifier, with the already reserved EMF data. When 

20 the reservation of the print job (EMF data + RAW data) 
is completed, the client 102 transmits, to the print 
server 101 (server 502), print request information (not 
including print data) consisting of the name of print 
data, the host name, the print request time, the 

25 printer name at the print output destination etc. the 

print server 101 executes order management of the print 
requests for the printer at each print output 
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destination, and, notifies a print permission to a 
client issuing the print request information or a next 
print order, when the network printer no longer has the 
print job awaiting the printing, namely the print job 
5 in execution. The print permission is constituted by 
the name of print data to be printed, the request time 
etc. 

Upon receiving the print instruction from the 
server 502, the client searches the permitted print job 

10 from the reservation job data 510 (or spooler 506) 

based on the information in the print permission. Then 
the RAW print data reserved in the reservation job data 
510 are read, and the monitor 507 transmits the read 
print data to the destination network printer 503 by 

15 LPR, whereby the printing operation is executed. As 
explained in the foregoing, the print server manages 
the order of printing while the client spools the print 
data and the client itself sends the print data to the 
network printer when the order of printing is reached, 

20 whereby the number of communications of the print data 
on the network is reduced to alleviate the load of the 
network. Also as the print server only manages the 
order of printing, there is not required a large 
spooler, and, because of the lighter load of 

25 processing, one of the clients may be used as an 
imaginary print server instead of providing an 
exclusive print server on the network (LAN). 
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The end-of-print notice processor 514 awaits the 
end-of -output event from the network printer 503, then, 
upon receiving the event, judges the remaining capacity 
of the reservation job directory set in the registry 
5 513, and, if the reservation is possible, sends an end- 
of -print notice to the reservation job transmitter 509. 

In response to the notice, the reservation job 
transmitter prepares a reservation job consisting of 
the print data (both EMF data and RAW data) and the 

10 print job information, and transmits the reservation 
job to the reservation job manager 512. The 
reservation job manager 512, receiving the reservation 
job, stores it as a reservation job file in a directory 
set in the registry 513. 

15 In case the end-of -print notice processor 514 

identifies that the reservation job cannot be reserved, 
the job is retained in a reservation waiting state 
without the issuance of the end notice therefor. For 
the jobs in the reservation waiting state, at the 

20 timing of periodic deletion of the reservation job 

exceeding the reservation period by the reservation job 
manager 512, an increase in the remaining capacity of 
the reservation directory is informed to the end-of- 
print notice processor 514, and a reservable job is 

25 identified from the jobs in the reservation waiting 
state and an end-of -print notice is given to the 
reservation job transmitter 509. As a result, the job 
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in the reservation waiting state is also reserved as a 
reservation job file, like the job for which the 
printing is completed. 

Also in case of re-printing of the reservation job 
5 file, the client 501 request a list of currently 
reserved jobs to the reservation job manager 512, 
which, in response, returns the content of the 
reservation job list 517. 

Receiving the list, the reservation job 

10 transmitter 509 causes the display unit to display the 
list of the print jobs reserved on the re-print GUI 
519, thereby requesting that the user selects an 
arbitrary reservation job and a destination printer. 
The present print control program designates the ID of 

15 the job and the destination printer, selected by the 
user, and request again the print data stored in the 
reservation job file, to the reservation job manager 
512. 

In response, the reservation job manager 512 
20 returns the print data, corresponding to the designated 
printer, from the designated reservation job file. The 
re-print GUI 519, receiving the print data through the 
reservation job transmitter 509, executes printing 
either through GDI or by sending the print data 
25 directly to the spooler, according to the kind (RAW or 
EMF) of the print data. The print data generated as a 
result of printing are formed by the reservation job 
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transmitter 509 as a new reservation job file 510 
constituted by RAW data and EMF data and are reserved 
in the server according to the aforementioned 
procedure. 

5 Thus, the present print job reservation management 

system can reserve the print jobs, printed from the 
plural clients 102 to 104, as reservation jobs in a 
designated location on the server (reservation job file 
515 in Fig. 6). 

10 The reservation process for the print job need not 

be executed for all the print jobs. Therefore, at the 
print instruction by the user on the client, the user 
is caused to designate whether to reserve the print job 
after printing or to delete it after printing. Now 

15 reference is made to Fig. 10 for explaining a property 
image of the printer driver displayed on the client. 
In the printer driver installed in the client, the user 
can set the print conditions utilizing an image shown 
in Fig. 10. In this user interface, the user can set 

20 the print resolution, gradation, graphic mode, sheet 
size, print layout, sheet direction, stamping etc. 

Also a "print job reservation" check box 1401, if 
checked, causes the client to reserve the print job in 
the server, after the end of printing. In case of 

25 printing without checking in the check box 1401, the 
print data reserved in the client are deleted without 
uploading in the server, after the printing in the 
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printer. 

Also a "reservation setting" button 1402 enables 
detailed setting for the reservation of the print job 
in the server. The reservation setting includes the 
5 reservation period, which is the period of reservation 
of the print job in the server, and the number of 
printing times. The number of printing times indicates 
an operation of deleting the print job reserved in the 
server after printings of a certain number of times, 

10 and such print job is reserved in the server until it 
is printed for such number of times. 

Also as the data of a device -independent EMF 
format and those of a device -dependent RAW format are 
reserved and either is selected according to the 

15 destination printer at the re-printing operation, it is 
rendered possible to output the reserved job to a 
destination different from that in the original 
operation, and, in case the destinations in both 
operations are same, there can be attained a re- 

20 printing operation with an increased throughput of 

printing. The present embodiment has been explained 
with the Windows system, but the present invention is 
not limited to such example and can be constructed on 
other operating systems such as OS/2. 

25 Fig. 11 is a flow chart showing an example of a 

first data processing sequence in the print system of 
the present invention, corresponding to the 
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end-of -print notifying process by the end-of -print 
notice processor 514 shown in Fig. 6. 

In summary, this sequence awaits an end-of -output 
event from the network printer 503, then judges whether 
5 the reservation as a reservation job is possible and 
notifying the print end to the reservation job 
transmitter 509. The end-of -print notice processor is 
provided as an event-driven permanent service, 
executing process by various events from the modules of 
10 the present invention, the network printer or the 
operating system. 

At first, a step S601 waits for an end-of -output 
event from the network printer, a change event for the 
reservation capacity, or an end event of the present 
15 invention. When an event occurs, a step S602 

discriminates whether it is an end event. If it is an 
end event from the operating system, the sequence is 
terminated after the internal memory is released. 

If the event is not an end event, a step S603 
20 discriminates whether it is an event for a change in 
the remaining capacity of the reservation directory. 
If so, a step S604 acquires a capacity for reservation 
in the reservation directory designated by the registry 
513. 

25 Then a step S605 compares sizes of the jobs, from 

the top of the reservation waiting list 518, with the 
reservable capacity, thereby searching a reservable 
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job. Then a step S606 discriminates whether a 
reservation job capable of being reserved, and, if not, 
the sequence returns to the step S601 for awaiting a 
next event . 

On the other hand, if the step S606 identifies a 
reservable job, a step S607 sends an end-of-print 
notice for such job by RPC to the reservation job 
transmitter 509. Then a step S608 deletes such job 
from the reservation waiting list 518 and adds it to 
the reservation job list 517. Then the sequence 
returns to the step S601 for awaiting a next event. 

On the other hand, if the step S603 identifies 
that the event is not an event for capacity change, a 
step S609 discriminates whether it is an end-of-print 
event. If not, the sequence returns to the step S601 
for awaiting a next event. If the step S609 identifies 
an end-of-print event from the network printer, a step 
S610 acquires a capacity for reservation in the 
reservation directory designated by the registry 513. 

Then a step S611 compares the size of the print 
job with the remaining capacity, and, if the 
reservation is possible, a step S612 sends an end-of- 
print notice for such job by RPC to the reservation job 
transmitter 509. 

Then a step S613 deletes such job from the 
reservation waiting list 516 and adds it to the 
reservation job list 517. Then the sequence returns to 
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the step S601 for awaiting a next event. 

On the other hand, if the 611 identifies that the 
reservation is not possible, a step S614 deletes the 
job from the print job list 516 and adds it to the 
5 reservation waiting list 518. Then the sequence 

returns to the step S601 for awaiting a next event. 

The end-of-print notice can be given only to the 
jobs reservable as the reservation jobs by the 
repetition of the above-described steps. 
10 Fig. 12 is a flow chart showing an example of a 

second data processing sequence in the print system of 
the present invention, corresponding to the reservation 
job transmitting process by the reservation job 
transmitter 509 shown in Fig. 6. 
15 in summary, this sequence prepares the reservation 

job from the print job data (RAW data) prepared in the 
printing process of the application 504 on the client 
PC 102 and the print job information. In this 
operation, there can be acquired the device- independent 
20 EMF data prior to the interpretation of the print data 
into the RAW data by the driver, by rendering effective 
the metafile spooling function in the system spooler. 
The EMF data, prepared in the aforementioned EMF 
spooler (not shown), are copied by the monitor 507 in 
25 another file (with extender EMF) having the job ID as 
the file name. Then, after confirmation of the proper 
functioning state of the server 502, the reservation 
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job consisting of the print job data including the EMF 
data and the print job information is transmitted to 
the reservation job manager of the server. If the 
transmission is not possible because of any trouble in 
the server, the reservation job is retained as the 
reservation job file in the client 501. The flow chart 
shows a process of transferring the retained 
reservation job file when the server is thereafter 
restored or when the capacity of the destination for 
reservation is secured. The reservation job 
transmitter is provided as an event-driven permanent 
service executing the process by various events from 
the modules of the present invention or from the 
operating system. 

At first, a step S701 waits for an end-of -output 
event or an end event, and, when an event occurs, a 
step S702 discriminates whether it is an end event. If 
it is an end event from the operating system, the 
sequence is terminated after the internal memory is 
released. 

If the event is not an end event, a step S703 
discriminates whether it is an end-of -print event, and, 
if not, the sequence returns to the step S701 for 
awaiting a next event. 

On the other hand, if the step S703 identifies an 
end-of -print event, a step S704 prepares a reservation 
job file from the print data consisting of the EMF data 
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and the RAW data and from the print job information, 
utilizing the job ID reserved in the monitor 507 as the 
file name. The file name is formed by changing the job 
ID into a character train (with extender SPL). 
5 Then a step S705 transfers the prepared 

reservation job file to the server 511 designated by 
the registry 511. Then a step S706 discriminates 
whether the transmission has been successful in proper 
manner, and, if the transmission is terminated by an 

10 error, the step S705 repeats the transfer. This 
procedure is repeated until the transmission is 
successfully completed. 

On the other hand, if the step S706 identifies a 
proper transfer, a step S707 deletes the reservation 

15 job file constituting the source of transmission, or 
the print data and the print job information used in 
preparing the reservation job file from the internal 
memory or the local disk. Thereafter the seguence 
returns to the step S701 for awaiting a next event. 

20 Thus the reservation job file consisting of the 

print job data and the print job information of a job 
of which the printing is completed can be transmitted 
by the repetition of the above-described steps. 

Fig. 13 is a flow chart showing an example of a 

25 third data processing seguence in the print system of 

the present invention, corresponding to the reservation 
job management process by the reservation job manager 
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512 shown in Fig. 6. 

In summary, this sequence reserves the reservation 
job transmitted from the reservation job transmitter 
512 of the client 501 as a reservation job file in a 
5 designated directory. The reservation job manager is 
provided as an event-driven permanent service, 
executing process by various events from the modules of 
the present invention or the operating system. 

At first, a step S801 waits for a reservation job 

10 reception event, a timer event or an end event, and, 

when an event occurs, a step S802 discriminates whether 
it is an end event. If it is an end event from the 
operating system, the sequence is terminated after the 
internal memory is released. 

15 if the event is not an end event, a step S803 

discriminates whether it is a timer event notified at a 
constant interval. If so, a step S804 searches a 
reservation job file, of which the reservation period 
designated by the registry 513 is exceeded. 

20 Then a step S605 discriminates whether a 

reservation job of which the reservation period is 
exceeded is found, and, if not found, the sequence 
returns to the step S801 for awaiting a next event. 

On the other hand, if the step S805 identifies a 

25 reservation job file of which the reservation period is 
exceeded, a step S806 deletes the reservation job file. 
Then a step S807 notifies the end-of -print notice 
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processor 514 of an increase in the remaining capacity 
of the directory storing the reservation job. 

In response, the end-of-print notice processor 514 
finds an appropriate reservation job from the 
5 reservation waiting job list 518 as explained in the 

foregoing and notifies the print end to the reservation 
job transmitter 509 of the client 102. As a result, 
the reservation job is transferred and a reception 
event is sent in the step S801 . The above-described 
10 process is repeated for the number of reservation job 
files found in the search of the step S804. Then the 
sequence returns to the step S801 for awaiting a next 
event . 

On the other hand, if the step S803 identifies 
15 that the event is not a timer event, a step S808 

discriminates whether it is a reception event. If not, 
the sequence returns to the step S801 for awaiting a 
next event . 

On the other hand, if the step S808 identifies 
20 that the event is a reception event, a step S809 
acquires the name of the reservation directory 
designated by the registry 513. Then a step S810 
prepares a file of a name same as that of the 
reservation job file in the reservation directory, and 
25 writes the reservation job file therein. 

Then a step S811 receives next reception data. A 
step S812 discriminates whether the reception data have 
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ended, and, if not, namely if the transmission is to be 
continued, the sequence returns to the step S810 for 
writing the received data in the reservation job file 
prepared in the foregoing. 
5 On the other hand, if the step S812 identifies 

that the reception data have ended, a step S813 writes 
the final reception data that have not been written 
into the file. Thereafter the sequence returns to the 
step S801 for awaiting a next event. 

10 Thus, the reservation job received by the 

reservation job manager 512 from the client 102 can be 
stored in the designated location, by the repetition of 
the above-described steps. 

The above-described embodiment allows the server 

15 apparatus to collectively manage only the jobs for 

which the printing has been completed, as reservation 
jobs, and also allows the client apparatus to reserve 
the print jobs instead of the server in case of a 
failure therein. Also, at an increase in the 

20 reservation capacity of the server, the reservation job 
can be automatically uploaded from the client 
apparatus, whereby the load of the user ion executing 
the data transfer on the client apparatus can be 
alleviated. 

25 Fig. 14 shows a re-print GUI (graphical user 

interface) provided and activated by the reservation 
job transmitter of the present invention. 



- 29 - 



The re-print GUI consists of input control, 
selection control and check control as illustrated. 
The name of the server computer for reserving the 
reservation job is entered in the reservation server 
5 name, and the reservation job list displays the content 
of the reservation list stored in the reservation 
server. The output printer name lists the printers 
available to the client computer, and the printer 
having attribute same as that of the job selected in 
10 the above-mentioned reservation job list is 

automatically current displayed. In the absence of the 
printer having the same attribute, there is not 
executed automatic adjustment and the current display 
is not altered. 

15 If "update reservation location" is checked, the 

content of such checking is transferred to the 
reservation job manager to be explained later, whereby 
the current reservation job file is deleted after the 
extraction of the print data and updated with the 

20 reservation job file reserved after the re-printing. 

Fig. 15 is a flow chart showing an example of a 
fourth data processing sequence in the print system of 
the present invention, and requesting the setting of 
re-printing by the user through the GUI provided by the 

25 re-print GUI providing module 519 (hereinafter called 
re-print GUI module) shown in Fig. 6. 

In a step S901, the re-print GUI module 519 
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activates the re-print GUI shown in Fig. 14. Then, in 
a step S902, the reservation job transmitter 509 
acquires the printer list ( EnumPrinters 0) available on 
the client computer, and adds it to the list control of 
5 the output printer names. 

In a step S903, the re-print GUI module 519 
discriminates whether a cancel button 1406 has been 
depressed. If the cancellation is instructed, the re- 
print GUI is terminated, but, if the cancellation is 

10 not instructed, the process is continued. 

In a step S904, the re-print GUI module 519 
requests the reservation job list to the reservation 
job manager of the reservation server 1401 designated 
by the user in the GUI shown in Fig. 14, utilizing RPC 

15 (remote procedure call). The reservation job list thus 
acquired is added to and displayed on the reservation 
job list control. 

In a step S905, the re-print GUI module 519 judges 
a job to be reprinted, selected by the user from the 

20 reservation jobs displayed in the reservation job list 
1402. Then, in a step S906, the re-print GUI module 
519 judges the printer selected by the user for the 
actual output from the output printer list 1403 of the 
pull-down window. Such judgment can be achieved by 

25 judging the candidate area clicked by a pointing device 
such as a mouse. 

In a step S907, the re-print GUI module 519 
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discriminates whether a check box 1404, indicating 
whether the location of reservation is updated by the 
user, is checked. If the updating of the location of 
reservation is selected, the selected reservation job 
5 is deleted and is replaced by a new reservation job 
reserved after the re-printing. 

Then, in a step S908, the re-print GUI module 519 
discriminates whether a re-print button 1405 is 
depressed. If it is depressed by the user, a step S909 

10 executes a re-printing process shown in Fig. 15, based 
on the reservation job ID, the name of the printer 
driver of the output printer and the reservation job 
selected in the foregoing process. The process is 
terminated by the depression either of the re-print 

15 button 1405 or of the cancel button. 

The process explained in the foregoing allows to 
activate the re-printing process of an arbitrary 
reservation job from the re-print GUI. 

Fig. 16 is a flow chart showing an example of a 

20 fifth data processing sequence in the print system of 
the present invention, and representing the process in 
the reservation job manager 512 in case the re-printing 
is executed . 

In a step S1001, the reservation job manager 512 
25 receives, through the re-print GUI 519 and from the 

reservation job transmitter, a request for extracting 
the print data (common file name receiving print data, 
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job ID, printer driver name and update flag) by RPC. 

In a step S1002, the reservation job manager 512 
searches the reservation job information from the 
reservation job list, based on the job ID received in 
5 the step S1001. If the search identifies that the 
designated reservation job is not registered in the 
list, an error is returned to the calling source. 

If the search identifies that the designated 
reservation job is registered, the reservation job 

10 manager 512 in a step S1004 compares the printer driver 
name stored in the reservation job list with the 
printer driver name of the output destination. If the 
comparison identifies different models, namely- 
different attributes, the reservation job manger 512 in 

15 a step S1010 extract the EMF data only from the 
reservation job file. 

On the other hand, if the step S1004 identifies a 
same model, namely a same attribute, the reservation 
job manager 512 in a 1005 extracts the RAW data only. 

20 It is thus rendered possible to avoid wasted data 
transfer. 

In a step S1006, the reservation job manager 512 
writes the extracted print data in the common file for 
print data writing, transferred in the step S1001. 
25 Then, in a step S1001, the reservation job manager 512 
writes the kind (RAW or EMF) of the print data in a 
return value to be returned to the calling source. The 
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writing of the print data to be transferred to the 
client is completed at this point. 

In a step S1008, the reservation job manager 512 
discriminates whether an update flag is set, and, if 
5 not, the sequence is immediately terminated, but, if 
set, a step S1009 deletes the reservation job file to 
be used as the basis of the re-printing. Such deletion 
eliminates the original reservation job file, but a new 
reservation job file is generated by the re-printing, 

10 so that the reservation job file is updated. 

Fig. 17 is a flow chart showing an example of a 
sixth data processing sequence in the print system of 
the present invention, and representing the process 
when the re-printing is executed. 

15 A step S1101 sets the items designated by the re- 

print GUI 519 as RPC parameters. Then a step S1102 
prepares a common file for receiving the print data. 
As a result of print data request by RPC, the print 
data are written into the common file. 

20 A step S1103 executes the process shown by the 

flow chart in Fig. 15, whereby the reservation job 
transmitter 509 receives the print data. A step SI 104 
discriminates the attribute of the print data stored in 
the return value, and, if the received print data are 

25 identified as EMF data, a step S1105 prepares a device 
context of the printing device (printer) according to 
the procedure of printing from the ordinary 
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application. The device con-text is a file including 
the attribute of the drawing sheet, the ability and 
attribute of the printer, and the printing can be 
realized by drawing in a metafile handle prepared from 
such device context. 

A step S1106 acquires the metafile handle from the 
acquired EMF data and the aforementioned device 
context. Then a step S1107 draws the EMF file. In EMF 
drawing, the GDI 508 generates the print data in 
cooperation with the printer driver, by calling an 
exclusive GDI function ( PlayMetaf ile 0 ) . 

A step S1108 deletes the metafile handle. Then a 
step SI 109 deletes the device context, thereby 
notifying the GDI of the end of printing. The 
generated print data are sent to the spooler at this 
point, thereby executing the ordinary printing. If the 
step S1104 identifies RAW data, a step Sllll opens the 
printer of destination and causes the spooler to 
directly transmit the print data. 

A step S1112 writes the print data received from 
the server directly into the printer, whereby the 
reserved print data are transferred without change to 
the printer. When all the print data are transferred, 
a step S1113 closes the printer. Then a step S1110 
deletes the common file which has received the print 
data. 

The above-described procedure allows to extract 
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the print data from the reservation jobs in the 
reservation server and to re-output the print data to 
the designated printer. 

In the following there will be explained, with 
reference to a memory map shown in Fig. 18, the 
configuration of the data processing program readable 
by the print system, in which the server apparatus and 
the client apparatus of the present invention are 
applicable. Fig. 18 shows the memory map of a memory 
medium storing various data processing programs 
readable by the server apparatus and the client 
apparatus of the present invention. 

Though not illustrated, there may also be stored 
information for managing the programs stored in the 
memory medium, such as version information or the 
producer of programs, and there may also be stored 
information dependent on the operating system of the 
program reading side, such as an icon for identifying 
the program. Also the data belonging to such programs 
are also managed by the aforementioned directory. 
Furthermore, there may also be stored a program for 
installing various programs into the computer, or a 
thawing program in case the program to be installed is 
compressed. 

The functions shown in Figs. 11 to 13 and 15 to 17 
may be attained by a host computer, according to a 
program to be installed from the exterior. Thus the 
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present invention is also applicable in a case where a 
group of information including the programs is supplied 
to the output apparatus from a memory medium such as a 
CD-ROM, a flush memory or an FD, or from an external 
5 memory medium through the network. 

Also the objects of the present invention can 
naturally be attained in a case where the program codes 
of a software realizing the functions of the 
aforementioned embodiments are supplied to a computer 
10 of a system or an apparatus and the functions of the 

aforementioned embodiments are realized by reading and 
executing the program codes by the computer (CPU or 
MPU) of the above-mentioned system or apparatus. In 
such case the program codes themselves read from the 
15 memory medium realize the novel functions of the 

present invention, and the program codes storing such 
program codes constitutes the present invention. 

The memory medium for supplying such program codes 
can be, for example, a floppy disk, a hard disk, an 
20 optical disk, a magnetooptical disk, a CD-ROM, a CD-R, 
a CD-RW, a DVD, a magnetic tape, a non-volatile memory 
card, a ROM or an EEPROM. 

The present invention also includes such program 
codes not only in a case where the functions of the 
25 aforementioned embodiments are realized by the 

execution of the read program codes by the computer but 
also a case where an operating system or the like 
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functioning on the computer executes all or a part of 
the actual processes under the control of such program 
codes thereby realizing the functions of the 
aforementioned embodiments. The present invention 
5 further includes a case wherein the program codes read 
from the memory medium are once stored in a memory 
provided in a function expansion board inserted into 
the computer or a function expansion unit connected to 
the computer, and a CPU provided in the function 

10 expansion board or the function expansion unit executes 
all the process or a part thereof according to the 
instructions of such program codes, thereby realizing 
the functions of the aforementioned embodiments. 
As explained in the foregoing, the present 

15 invention allows the server apparatus to collectively 
manage only the jobs for which the printing has been 
completed, as reservation jobs, and also allows the 
client apparatus to reserve the print jobs instead of 
the server in case of a failure therein. Also, at an 

20 increase in the reservation capacity of the server, the 
reservation job can be automatically uploaded from the 
client apparatus. Also when the client extracts the 
reservation job reserved in the server, an identical 
print image can be reproduced in case of output to a 

25 same printer and an output close to the original print 
image by the EMF data in case of output to a different 
printer. 
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As many apparently widely different embodiments of 
the present invention can be made without departing 
from the spirit and scope thereof, it is to be 
understood that the invention is not limited to the 
specific embodiments thereof except as defined in the 
appended claims. 
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WHAT IS CLAIMED IS: 

1 . A print server apparatus capable of receiving 
a print job to be printed from an information 
processing apparatus through a network, the printer 
5 server apparatus comprising: 

reservation job management means for storing, in a 
memory, reservation job data prepared by uniting print 
data to be printed by a printing apparatus and print 
job information, received from said information 
10 processing apparatus, and managing said reservation job 
data even after completion of the printing process by 
said printing apparatus; and 

output control means for outputting the 
reservation job data managed by said reservation job 
15 management means to the exterior, according to a 

request for re-printing received from said information 
processing apparatus. 

2. A print server apparatus according to claim 1, 
20 wherein said reservation job management means is 

adapted to reserve the reservation job data transmitted 
from said information processing apparatus for a 
designated period and to delete said reservation job 
data from said memory after the lapse of said 
25 designated period. 



3 . A print server apparatus according to claim 1 , 
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further comprising discrimination means for 
discriminating whether the management of said 
reservation job data by said reservation job management 
means is possible, in response to a request for 
5 reservation from said information processing apparatus; 
wherein said reservation job management means 
executes reservation and management of said reservation 
job data in case said discrimination means identifies 
that the management of said reservation job data is 
10 possible. 

4. A print server apparatus according to claim 3, 
wherein, in case said discrimination means identifies 
that the management of said reservation job data is not 
15 possible, said reservation job management means 
registers and manages the print job ID and the 
reservation job size, requested for reservation, in a 
reservation waiting list. 

20 5. A print server apparatus according to claim 4, 

further comprising detection means for detecting a 
registerable print job ID by comparing the available 
capacity of said memory with the reservation job sizes 
registered in said reservation waiting list. 



6. A print server apparatus according to claim 1, 
wherein : 
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said reservation job management means manages 
print data of a device-dependent data format and 
intermediate data of a device- independent data format ; 
and 

in case the location of printing indicated by a 
re-print request received from said information 
processing apparatus is a printing apparatus of a type 
same as that of the printing apparatus executing the 
original printing, said output control means outputs 
the device-dependent print data managed by said 
reservation job management means to the exterior, but, 
in case the location of printing indicated by the re- 
print request received from said information processing 
apparatus is a printing apparatus of a type different 
from that of the printing apparatus executing the 
original printing, said output control means outputs 
the device- independent intermediate data managed by 
said reservation job management means to the exterior. 

7. A print server apparatus according to claim 6, 
wherein said intermediate data are EMF data and said 
print data are RAW data. 

8 . An information processing apparatus for 
generating print data to be printed by a printing 
apparatus through a network, the information processing 
apparatus comprising: 
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print data generation means for generating the 
print data to be printed by said printing apparatus ; 

reservation data generation means for generating 
reservation job data consisting of said print data and 
5 print job information based on said print data and to 
be reserved after the completion of the printing 
process of said print data by said printing apparatus ; 
and 

transmission control means for transmitting the 
10 reservation job data, generated by said reservation 
data generation means, to a print job management 
apparatus through the network. 

9 . An information processing apparatus according 
15 to claim 8, further comprising condition designation 
means for designating a reservation condition for 
causing said print job management apparatus to reserve 
the reservation job data. 

20 10. An information processing apparatus according 

to claim 9, wherein said reservation condition is a 
period of reservation. 



25 



11. An information processing apparatus according 
to claim 9, wherein said reservation condition is a 
number of printing times. 
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12. An information processing apparatus according 
to claim 8, wherein said reservation data generation 
means generates reservation data including said print 
data of a device-dependent data format and intermediate 

5 data of a device-independent data format. 

13. An information processing apparatus according 
to claim 12, further comprising: 

acquisition means for acquiring a list of managed 
10 reservation data from said print job management 
apparatus ; and 

re-print designation means for designating the 
reservation data to be re-printed from said acquired 
list of the reservation data. 

15 

14. An information processing apparatus according 
to claim 13, wherein, in case of receiving the 
intermediate data from said print job management means 
according to a re-printing instruction by said re-print 

20 designation means, print data generation means 

corresponding to the printing apparatus to be used for 
re-printing is selected among plural print data 
generation means, and the print data for said printing 
apparatus to be used for re-printing are generated from 

25 said intermediate data. 



15. An information processing apparatus according 
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•to claim 14, wherein the print data generated at the 
re-printing of the intermediate data are reserved again 
as the reservation job data in said print job 
management apparatus. 

5 

16. A method for use in a print server apparatus 
capable of receiving a print job to be printed from an 
information processing apparatus through a network, the 
method comprising: 

10 a reservation job management step of storing, in a 

memory, reservation job data prepared by uniting print 
data to be printed by a printing apparatus and print 
job information, received from said information 
processing apparatus, and managing said reservation job 

15 data even after completion of the printing process by 
said printing apparatus; and 

an output control step of outputting the 
reservation job data managed by said reservation job 
management step to the exterior, according to a request 

20 for re-printing received from said information 
processing apparatus. 

17. A method according to claim 16, wherein said 
reservation job management step is adapted to reserve 

25 the reservation job data transmitted from said 

information processing apparatus for a designated 
period and to delete said reservation job data from 
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said memory after the lapse of said designated period. 

18. A method according to claim 16, further 
comprising a discrimination step of discriminating 
5 whether the management of said reservation job data by 
said reservation job management step is possible, in 
response to a request for reservation from said 
information processing apparatus; 

wherein said reservation job management step 
10 executes reservation and management of said reservation 
job data in case said discrimination step identifies 
that the management of said reservation job data is 
possible. 

15 19. A method according to claim 18, wherein, in 

case said discrimination step identifies that the 
management of said reservation job data is not 
possible, said reservation job management step 
registers and manages the print job ID and the 

20 reservation job size, requested for reservation, in a 
reservation waiting list. 

20. A method according to claim 19, further 
comprising a detection step of detecting a registerable 
25 print job ID by comparing the available capacity of 

said memory with the reservation job sizes registered 
in said reservation waiting list. 
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21. A method according to claim 16, wherein: 
said reservation job management step manages print 

data of a device-dependent data format and intermediate 
data of a device- independent data format; and 

in case the location of printing indicated by a 
re-print request received from said information 
processing apparatus is a printing apparatus of a type 
same as that of the printing apparatus executing the 
original printing, said output control means outputs 
the device-dependent print data managed by said 
reservation job management means to the exterior, but, 
in case the location of printing indicated by the re- 
print request received from said information processing 
apparatus is a printing apparatus of a type different 
from that of the printing apparatus executing the 
original printing, said output control means outputs 
the device- independent intermediate data managed by 
said reservation job management means to the exterior. 

22. A method according to claim 21, wherein said 
intermediate data are EMF data and said print data are 
RAW data. 

23. An information processing method for 
generating print data to be printed by a printing 
apparatus through a network, the method comprising: 

a print data generation step of generating the 
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print data to be printed by said printing apparatus; 

a reservation data generation step of generating 
reservation job data consisting of said print data and 
print job information based on said print data and to 
5 be reserved after the completion of the printing 

process of said print data by said printing apparatus; 
and 

a transmission control step of transmitting the 
reservation job data, generated by said reservation 
10 data generation step, to a print job management 
apparatus through the network. 



24. An information processing method according to 
claim 23, further comprising a condition designation 
15 step of designating a reservation condition for causing 
said print job management apparatus to reserve the 
reservation job data. 



25. An information processing method according to 
20 claim 24, wherein said reservation condition is a 
period of reservation. 



26. An information processing method according to 
claim 24, wherein said reservation condition is a 
25 number of printing times. 



27. An information processing method according to 
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claim 23, wherein said reservation data generation step 
generates reservation data including said print data of 
a device-dependent data format and intermediate data of 
a device- independent data format. 

5 

28. An information processing method according to 
claim 27, further comprising: 

an acquisition step of acquiring a list of managed 
reservation data from said print job management 
10 apparatus; and 

a re-print designation step of designating the 
reservation data to be re-printed from said acquired 
list of the reservation data. 

15 29 . An information processing method according to 

claim 28 , wherein, in case of receiving the 
intermediate data from said print job management step 
according to a re-printing instruction by said re-print 
designation step, print data generation means 

20 corresponding to the printing apparatus to be used for 
re-printing is selected among plural print data 
generation means, and the print data for said printing 
apparatus to be used for re-printing are generated from 
said intermediate data. 

25 

30. An information processing method according to 
claim 29, wherein the print data generated at the 
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re-printing of the intermediate data are reserved again 
as the reservation job data in said print job 
management apparatus . 

5 31- A computer readable memory medium storing a 

program of a method for use in a print server apparatus 
capable of receiving a print job to be printed from an 
information processing apparatus through a network, the 
program comprising: 

10 a reservation job management step of storing, in a 

memory, reservation job data prepared by uniting print 
data to be printed by a printing apparatus and print 
job information, received from said information 
processing apparatus, and managing said reservation job 

15 data even after completion of the printing process by 
said printing apparatus; and 

an output control step of outputting the 
reservation job data managed by said reservation job 
management step to the exterior, according to a request 

20 for re-printing received from said information 
processing apparatus. 

32. A memory medium according to claim 31, 
wherein said reservation job management step is adapted 
25 to reserve the reservation job data transmitted from 

said information processing apparatus for a designated 
period and to delete said reservation job data from 
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said memory after the lapse of said designated period. 

33. A memory medium according to claim 31, the 
program further comprising a discrimination step of 
5 discriminating whether the management of said 

reservation job data by said reservation job management 
step is possible, in response to a request for 
reservation from said information processing apparatus; 

wherein said reservation job management step 
10 executes reservation and management of said reservation 
job data in case said discrimination step identifies 
that the management of said reservation job data is 
possible. 

15 34. A memory medium according to claim 33, 

wherein, in case said discrimination step identifies 
that the management of said reservation job data is not 
possible, said reservation job management step 
registers and manages the print job ID and the 

20 reservation job size, requested for reservation, in a 
reservation waiting list. 

35. A memory medium according to claim 34, the 
program further comprising a detection step of 
25 detecting a registerable print job ID by comparing the 
available capacity of said memory with the reservation 
job sizes registered in said reservation waiting list. 
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36. A memory medium according to claim 31, 
wherein: 

said reservation job management step manages print 
data of a device-dependent data format and intermediate 
5 data of a device-independent data format; and 

in case the location of printing indicated by a 
re-print request received from said information 
processing apparatus is a printing apparatus of a type 
same as that of the printing apparatus executing the 

10 original printing, said output control step outputs the 
device-dependent print data managed in said reservation 
job management steps to the exterior, but, in case the 
location of printing indicated by the re-print request 
received from said information processing apparatus is 

15 a printing apparatus of a type different from that of 

the printing apparatus executing the original printing, 
said output control step outputs the device- independent 
intermediate data managed in said reservation job 
management step to the exterior. 

20 

37. A memory medium according to claim 36, 
wherein said intermediate data are EMF data and said 
print data are RAW data. 

25 38. A computer readable memory medium storing a 

program of an information processing method for 
generating print data to be printed by a printing 
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apparatus through a network, the program comprising: 
a print data generation step of generating the 
print data to be printed by said printing apparatus ; 

a reservation data generation step of generating 
5 reservation job data consisting of said print data and 
print job information based on said print data and to 
be reserved after the completion of the printing 
process of said print data by said printing apparatus; 
and 

10 a transmission control step of transmitting the 

reservation job data, generated by said reservation 
data generation step, to a print job management 
apparatus through the network. 



15 39. A memory medium according to claim 38, the 

program further comprising a condition designation step 
of designating a reservation condition for causing said 
print job management apparatus to reserve the 
reservation job data. 

20 

40. A memory medium according to claim 39, 
wherein said reservation condition is a period of 
reservation . 



25 



41. A memory medium according to claim 39, 
wherein said reservation condition is a number of 
printing times. 



- 53 - 



42. A memory medium according to claim 38, 
wherein said reservation data generation step generates 
reservation data including said print data of a device- 
dependent data format and intermediate data of a 

5 device- independent data format. 

43. A memory medium according to claim 42, the 
program further comprising: 

an acquisition step of acquiring a list of managed 
10 reservation data from said print job management 
apparatus; and 

a re-print designation step of designating the 
reservation data to be re-printed from said acquired 
list of the reservation data. 

15 

44. A memory medium according to claim 43, 
wherein, in case of receiving the intermediate data 
from said print job management step according to a re- 
printing instruction by said re-print designation step, 

20 print data generation means corresponding to the 
printing apparatus to be used for re-printing is 
selected among plural print data generation means, and 
the print data for said printing apparatus to be used 
for re-printing are generated from said intermediate 

25 data. 



45. A memory medium according to claim 44, 
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wherein the print data generated at the re-printing of 
the intermediate data are reserved again as the 
reservation job data in said print job management 
apparatus. 

5 

46 . A computer program of a method for use in a 
print server apparatus capable of receiving a print job 
to be printed from an information processing apparatus 
through a network, the program comprising: 

10 a reservation job management step of storing, in a 

memory reservation job data prepared by uniting print 
data to be printed by a printing apparatus and print 
job information, received from said information 
processing apparatus, and managing said reservation job 

15 data even after completion of the printing process by 
said printing apparatus; and 

an output control step of output ting the 
reservation job data managed by said reservation job 
management step to the exterior, according to a request 

20 for re-printing received from said information 
processing apparatus. 

47. A computer program according to claim 46, 
wherein said reservation job management step is adapted 

25 to reserve the reservation job data transmitted from 

said information processing apparatus for a designated 
period and to delete said reservation job data from 
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said memory after the lapse of said designated period. 

48. A computer program according to claim 46, 
further comprising a discrimination step of 
5 discriminating whether the management of said 

reservation job data by said reservation job management 
step is possible, in response to a request for 
reservation from said information processing apparatus; 

wherein said reservation job management step 
10 executes reservation and management of said reservation 
job data in case said discrimination step identifies 
that the management of said reservation job data is 
possible. 

15 49. A computer program according to claim 48, 

wherein, in case said discrimination step identifies 
that the management of said reservation job data is not 
possible, said reservation job management step 
registers and manages the print job ID and the 

20 reservation job size, requested for reservation, in a 
reservation waiting list. 

50. A computer program according to claim 49, the 
program further comprising a detection step of 
25 detecting a registerable print job ID by comparing the 
available capacity of said memory with the reservation 
job sizes registered in said reservation waiting list. 
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51. A computer program according to claim 46, 
wherein: 

said reservation job management step manages print 
data of a device-dependent data format and intermediate 
5 data of a device- independent data format; and 

in case the location of printing indicated by a 
re-print request received from said information 
processing apparatus is a printing apparatus of a type 
same as that of the printing apparatus executing the 

10 original printing, said output control step outputs the 
device-dependent print data managed in said reservation 
job management step to the exterior, but, in case the 
location of printing indicated by the re-print request 
received from said information processing apparatus is 

15 a printing apparatus of a type different from that of 

the printing apparatus executing the original printing, 
said output control step outputs the device- independent 
intermediate data managed in said reservation job 
management step to the exterior. 

20 

52. A computer program according to claim 51, 
wherein said intermediate data are EMF data and said 
print data are RAW data. 

25 53 . A computer program of an information 

processing method for generating print data to be 
printed by a printing apparatus through a network, the 
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program comprising: 

a print data generation step of generating the 
print data to be printed by said printing apparatus; 

a reservation data generation step of generating 
5 reservation job data consisting of said print data and 
print job information based on said print data and to 
be reserved after the completion of the printing 
process of said print data by said printing apparatus; 
and 

10 a transmission control step of transmitting the 

reservation job data, generated by said reservation 
data generation step, to a print job management 
apparatus through the network. 



15 54. A computer program according to claim 53, 

further comprising a condition designation step of 
designating a reservation condition for causing said 
print job management apparatus to reserve the 
reservation job data. 

20 

55. A computer program according to claim 54, 
wherein said reservation condition is a period of 
reservation . 



25 



56. A computer program according to claim 54, 
wherein said reservation condition is a number of 
printing times . 
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57. A computer program according to claim 53 , 
wherein said reservation data generation step generates 
reservation data including said print data of a device- 
dependent data format and intermediate data of a 

5 device- independent data format. 

58. A computer program according to claim 57, 
further comprising: 

an acquisition step of acquiring a list of managed 
10 reservation data from said print job management 
apparatus; and 

a re-print designation step of designating the 
reservation data to be re-printed from said acquired 
list of the reservation data. 

15 

59. A computer program according to claim 58, 
wherein, in case of receiving the intermediate data 
from said print job management step according to a re- 
printing instruction by said re-print designation step, 

20 print data generation means corresponding to the 
printing apparatus to be used for re-printing is 
selected among plural print data generation means, and 
the print data for said printing apparatus to be used 
for re-printing are generated from said intermediate 

25 data. 



60. A computer program according to claim 59, 
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wherein the print data generated at the re-printing of 
the intermediate data are reserved again as the 
reservation job data in said print job management 
apparatus . 
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ABSTRACT OF THE DISCLOSURE 

The invention is featured by a configuration, for 
notifying the end of printing to the client in 
asynchronous manner for the print job that cannot be 
5 reserved in the server, of judging the writing capacity 
of the reservation job file of the server prior to the 
notification of the end of printing to the client 
apparatus, and, only in case the reservation is 
possible, the reservation job manager notifies the end 
10 of printing to the client apparatus but, in case the 

reservation is not possible, the print job that cannot 
be reserved is managed in a reservation waiting state. 
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